-
Notifications
You must be signed in to change notification settings - Fork 24.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fixing the git attrs for all the people and all the files and all future 🙌 #31128
Conversation
I think the
|
I'm not sure since when this was fine. I guess we could keep it 🤷? But I think it's been a while, so I would opt for not having it 🤔. |
Base commit: cdf3182 |
Base commit: cdf3182 |
Yes, that's true. It's actually not the settings that are recommended by the iOS community anyway. |
Allowing pbxproj files to diff can be problematic. Due to autogenerated IDs you can't easily merge changesets from different people. The git docs even call out marking them as binary to prevent diffing: https://git-scm.com/book/en/v2/Customizing-Git-Git-Attributes#_binary_files
|
Yup. This is a known issue, and I hope sometime we will solve it with xcodegen or something similar. But these files are changing and it's important to know what is changed. They are too fragile to just commit without paying attention. The upgrade helper diffs them and even with ids changing, it's important to know what's there and what's changed. (Oof, never seen that the git docs have the xcode file as example. That's bad. You can and should merge things in that file. Otherwise you lose changes, and that's the point of git. Yes, it's hard because that file was not well-designed. But it's the same as |
Oh, I agree the changes are important. 😄 Personally, I just subscribe to a different resolution method - look at what the changes produce in the xcodeproj and then use Xcode itself to generate the changes again via the UI. That way there's no chance of misaligned IDs, 'Recovered References', etc. |
Not reliant for this PR, but there was a get mergetool tool that would parse, attempt to understand, and then merge the project files automatically:
It's not been updated for a long time though, so I have no idea if it would still work. Anyway! That's not what this PR is about 🙂 |
Thanks for the PR @pvinis - Before merging this, I would like to understand the problems you were facing a bit better. Let's have a quick look at the Gradle Wrapper scripts on the current master branch in this repo:
Everything looks correct to me. So first question: Why is there a need to "renormalize" the files, and why do they show up as changed in the PR diff? |
I just checked the third commit on your branch ( I think (please correct me if I'm wrong), the purpose of this PR is to add the |
Also just a minor addition regarding |
Right, so for pbxproj, it's cool, we keep it away. No need for it anymore. For the rest, the problem we faced was that everytime someone did a change in these bat files, the whole thing would change because the line endings would change depending if people did the change in win or mac. The normalization is something that apparently git needs. I tried to look at the code of git but it got a bit tricky, and the docs are not suuuuuuper helpful, but from what I see, if a file was committed at some point with LF, git thinks it's always LF from then on. So from my understanding, after renormalizing, git now understands the right line endings. So after doing the renormalization, I tried to edit files again on mac and win, and there was only my changes that time. No more changing the whole file etc. So I think now everything is good. Could you try to edit a bat file on mac (and win if you have) and see if they come up as just the diff you did? If it is, then all is fixed and well. If you get the whole file changing again, then something is up. Try and let me know? |
Sorry I don't quite understand. Can you explain in more detail? If you check my message above, you can see that these files already have the correct line endings. What I think is happening here is your editor is converting entire files when you are only editing single lines as a side effect. That's clearly not what should happen. Can you please try:
Again, as I mentioned, all files are already in their expected standard format - there is no need for any conversion and/or addition of new files that configure settings to the default value. |
I can try tomorrow. Are you in the RN discord or somewhere else where we could talk faster, so I can try and then we can talk and see what's up? |
@pvinis @friederbluemle did you get a chance to discuss this PR? Let us know if we should consider it for merging, or if there's any more work that needs to be done. |
@hramos has imported this pull request. If you are a Facebook employee, you can view this diff on Phabricator. |
Considering the contents of this PR have already been incorporated onto 0.64 and no issues have been reported, we are going to proceed with merging this PR. |
… all future (facebook#31128)" This reverts commit 7384471.
@hramos - Thanks for the reminder. Can you please check my comment above? As explained - The files already had the correct line endings in the repository (there is no need to add gitattributes or editorconfig). Now that it's merged, the Windows .bat files have their CRLF endings removed, which is incorrect. I've reverted it here: #31398
Again, @pvinis to confirm if that works locally. Thanks! |
I'll check this right now. |
Ok let's go.
As extras, I will try to edit these files and commit, and see if they stay with the correct line endings. I will also take a look at your new PR.
So my final thoughts here are:
I think the new PR you made is not actually needed, but please, if you try to replicate all the above in a fresh master with my changes in there, and maybe even in a fresh repo on your branch, and something is handled in a better way on yours, then let me know! I am also happy to check stuff together on discord or wherever else. |
@pvinis - Thanks a lot for the detailed response and analysis 👍
I admit, it's not immediately obvious, but what you checked here are the files in your working directory, not the files stored in the repository. That's because now that there is a If you want to see how these files are actually stored:
The file only has
Alternatively, if you use something like
|
I will check these again and report back. But just as a quick response, I definitely care in order:
|
… all future (facebook#31128)" This reverts commit 7384471.
… all future (facebook#31128)" This reverts commit 7384471.
Summary: This reverts #31128 - For the reasons stated in the thread. Files should have the correct endings in the repo (i.e. Windows .bat CRLF). There is no reason to perform additional conversion with attributes and/or an editorconfig. It was originally fixed in #29792 in August 2020. :warning: **EDIT 2021-08-31** Commits 85249ca and 13107fa accidentally converted the gradlew.bat files to LF again, resulting in modified files to appear in the working directory: ``` $ git status -s M gradlew.bat M packages/react-native-codegen/android/gradlew.bat M template/android/gradlew.bat ``` The reasons why this is happening are explained in detail in the two PRs linked above. I've added an additional (new) commit to the PR head branch to fix the line endings in all three `gradlew.bat` files of the repo and rebased it. It should be ready for merge. CC cortinico EDIT 2021-09-02 The additional commit was removed again, but the original one remains. To test the scenario locally run the following commands on a clean `main` branch (currently 455433f): ``` $ rm gradlew.bat $ git status -s D gradlew.bat # Git shows the file as (D)eleted, as expected $ git checkout gradlew.bat # This should restore the file $ git status -s M gradlew.bat # The file still shows up, now as (M)odified with all line endings changed ``` The modified file will remain in the working directory until they are committed, or a different branch is _force_ checked out. `gradlew.bat` files are generated automatically by Gradle (with the correct line endings in the first place). There is no need to special case them and perform line ending conversion using Git and/or editorconfig. ## Changelog [General] [Fixed] - Line endings in Windows files, Git/EditorConfig related conversions Pull Request resolved: #31398 Test Plan: Verify files are stored correctly in the repository (e.g. using the `file` command). Reviewed By: yungsters Differential Revision: D30839864 Pulled By: cortinico fbshipit-source-id: dfc53e8c5d9276d2f9bfd4d4a4e6b44c3143a164
More info at fabOnReact/react-native-notes#8 facebook#31128 (comment) >If you want to see how these files are actually stored: >Remove .gitattributes (so that no conversion happens) I solved the problem with the following steps: 1) checkout branch I want to rebase 2) the branch was already rebased and included commit facebook@7384471 which brought `.gitattributes` file in the branch The file below triggers the error `error: add_cacheinfo failed to refresh for path 'packages/react-native-gradle-plugin/gradlew.bat'; merge aborting.` when running `git merge master`. ``` -# Windows files should use crlf line endings -# https://help.github.com/articles/dealing-with-line-endings/ -*.bat text eol=crlf ``` 3) I remove the `.gitattributes` files from the branch. 4) `git` stops converting the line ending 5) I merge main branch. `.gitattributes` files was already removed from main branch with https://github.com/facebook/react-native/pull/31398/files. Git runs the merge without problems. Also no diff because the file already deleted from main.
More info at fabOnReact/react-native-notes#8 facebook#31128 (comment) >If you want to see how these files are actually stored: >Remove .gitattributes (so that no conversion happens) I solved the problem with the following steps: 1) checkout branch I want to rebase 2) the branch was already rebased and included commit facebook@7384471 which brought `.gitattributes` file in the branch The file below triggers the error `error: add_cacheinfo failed to refresh for path 'packages/react-native-gradle-plugin/gradlew.bat'; merge aborting.` when running `git merge master`. ``` -# Windows files should use crlf line endings -# https://help.github.com/articles/dealing-with-line-endings/ -*.bat text eol=crlf ``` 3) I remove the `.gitattributes` files from the branch. 4) `git` stops converting the line ending 5) I merge main branch. `.gitattributes` files was already removed from main branch with https://github.com/facebook/react-native/pull/31398/files. Git runs the merge without problems. Also no diff because the file already deleted from main.
Summary
We have had problems with
.gitattributes
,.bat
and.pbxproj
(Xcode) files for a while. The two main concerns were:This PR fixes both issues, hopefully forever.
After seeing the diffs from v0.63 -> v0.64 and the changes in #29792, I, again, felt that this is going to cause problems, so I looked into both issues.
I started with
git check-attr -a Artsy.xcodeproj/project.pbxproj
after removing the.gitattributes
file that contained*.pbxproj -text
and there are no "guessed" attributes that would break things, and diffing and checking in worked well with the current git version. I agree this is not needed, so I left it out.I looked into what it was doing before, and it was telling git (for the xcode project file) to "unset text", which means (according to https://git-scm.com/docs/gitattributes#_text) that it should not try to do any line ending changes when checking in that file. At some point git must have done this, and that's why it was needed, but no more, so it's safe and good to get rid of this, as it helps with nothing anymore.
Now for the bat files. We don't need any extra instructions for
gradle
and*.sh
files as they are guessed correctly, so these are also safe to keep removed (https://github.com/facebook/react-native/pull/29792/files#diff-618cd5b83d62060ba3d027e314a21ceaf75d36067ff820db126642944145393eL5).But we do need the
*.bat
instruction. I noticed that when working on macOS there were two problems that made things funky.To fix the first one, I added a rule in
.editorconfig
(that's whats important, when any editor just supports editorconfig, but all my editors do). I can't believe how we missed that for sooooo long 😅!To fix the second, I added the
.gitattributes
instruction andrenormalize
d the files (https://git-scm.com/docs/git-add#Documentation/git-add.txt---renormalize and https://docs.github.com/en/github/using-git/configuring-git-to-handle-line-endings#refreshing-a-repository-after-changing-line-endings). I think the problem all along was that even though the files had crlf, git still thought they were using lf.After the editorconfig change and the renormalization, everything behaves correctly and as expected. Changing bat files on macOS and Windows is fine now, producing only the smallest change needed, no random line ending diffs. Also here is a screenshot of one of the files actually crlf. It's these tiny things at the end of each line 👓.
I have tested this on macOS and Windows, doing changes in both bat and xcode files, and verified that diffing and checking in files works well.
Changelog
[General] [Added] - Added an
.editorconfig
file to help with default line endings for Windows files.[Internal] [Fixed] - Added a rule in
.editorconfig
and.gitattributes
to help with default line endings for Windows files.Test Plan
Feel free to go on a macOS or Windows machine (or both) and, using any editor that supports editorconfig, do any change in a
.bat
file. Then look at your git diff in terminal or gui or whatever you use, and then look at the sky and smile. It's fixed. The diff is just your change. Everything is as it should 💜.